<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>全局组件&局部组件</title>
  <script src="../js/vue.js"></script>
</head>

<body>

  <div id="app">
    <my-cpn></my-cpn>
    <cpnn></cpnn>
  </div>
  <hr>
  <div id="app2">
    <my-cpn></my-cpn>
    <!-- 未定义，报警告信息 -->
    <cpnn></cpnn>
  </div>

  <script>
    // 创建组件
    // 1. 创建组件构造器对象
    const cpn = Vue.extend({
      template: `
      <div>
        <h2>我是标题-全局组件</h2>
          <p>我是内容，哈哈哈</p>
          <p>我是内容，呵呵呵呵呵</p>
      </div>`
    });
    // 2、 注册组件 Vue.component('组件标签名'，'组件构造器'')
    Vue.component('my-cpn', cpn);

    const cpnC = Vue.extend({
      template: `
      <div>
        <h2>我是标题-局部组件</h2>
          <p>我是内容，哈哈哈</p>
          <p>我是内容，呵呵呵呵呵</p>
      </div>`
    });


    var vm = new Vue({
      el: '#app',
      data: {
        message: '你好啊'
      },
      methods: {},
      // 局部组件
      components: {
        cpnn: cpnC
      }
    });

    var vm2 = new Vue({
      el: '#app2',
      data: {
        message: '你好啊'
      },
      methods: {}

    });
  </script>
</body>

</html>